package leetcode; /**
 * description:
 * author:张腾
 * date:2021-07-11
 */

import java.util.Arrays;
import java.util.HashMap;
import java.util.Map;

/**
 * 给定一位研究者论文被引用次数的数组（被引用次数是非负整数）。编写一个方法，计算出研究者的 h指数。
 *
 * h 指数的定义：h 代表“高引用次数”（high citations），一名科研人员的 h 指数是指他（她）的 （N 篇论文中）总共有 h 篇论文分别被引用了至少 h 次。且其余的N - h篇论文每篇被引用次数不超过 h 次。
 *
 * 例如：某人的 h 指数是 20，这表示他已发表的论文中，每篇被引用了至少 20 次的论文总共有 20 篇。
 */
public class leetcode274 {
    public int hIndex(int[] citations) {

        Arrays.sort(citations);
        for (int i = citations.length-1; i >= 0; i--) {
            if (citations.length-i>=citations[i]) return citations[i];
        }
        int ans=0,t = 0;
        for (int i = 0; i < citations.length; i++) {
            if (citations.length-i>=citations[i]) ans = citations[i];
            else t++;
        }
        return Math.max(t,ans);
    }
}
